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2 (57) Abstract: The invention relates to a method for transmitting a software code from a control unit to a field device of process 
^ automation technology. The inventive method is characterized in that the software code is integrated into a software module which 
encapsulates data and functions of the field device and which requires an operator control program for field devices as the runtime 
O environment and which establishes the communication link with the field device. 
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(57) Zusammenfassung: Bei einem Verfahren zum Ubertragen von Softwarecode von einer Steuereinheit zu einem Feldgerat der 
Prozessautomatisierungstechnik ist der Softwarecode in einem Softwaremodul integriert, das Daten und Funktionen des Feldgerates 
kapselt und als Laufzeitumgebung ein Bedienprogramm fiir Feldgerate benotigt und das die Kommunikationsverbindung mit dem 
Feldgerat herstellt. 
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Verffahren sur Ubortragung von Sofiwarecode von emer Steuoreinheit zu 
einem Feldgerat der Prozessautomatisierungstechnik 

Die Erfindung betrifft ein Verfahren zur Ubertagung von Softwarecode von einer 
Steuereinheit zu einem Feldgerat der Prozessautomatisierungstechnik gemafi 
dem Oberbegriff des Anspruchs 1 . 

In der Prozessautomatisierungstechnik werden vielfach Feldgerate eingesetzt, 
die zur Erfassung und/oder Beeinflussung von Prozessvariablen dienen. 
Beispiele fur derartige Feldgerate sind Fullstandsmesser, 
Massendurchflussmessgerate, Druck- und Temperaturmessgerate etc., die als 
Sensoren die entsprechende Prozessvariablen Fullstand, Durchfluss, Druck 
bzw. Temperatur erfassen. 

Zur Beeinflussung von Prozessvariablen dienen sogenannte Aktoren z. B. 
Ventile, die den Durchfluss einer Flussigkeit in einem Rohrleitungsabschnitt oder 
Pumpen, die den Fullstand in einem Behalter verandem. 

Eine Vielzahl solcher Feldgerate wird von der Fa. Endress+Hauser hergestellt 
und vertrieben. 

In der Regel sind die Feldgerate uber einen Feldbus (Profibus®, Foundation® 
Fieldbus, etc.) mit Leitsystemen oder Steuereinheiten verbunden. Diese dienen 
zur Prozesssteuerung, Prozessvisualisierung, Prozessuberwachung sowie zur 
Konfigurierung und Parametrierung der Feldgerate. 

Die Feldgerate fuhren verschiedene Funktionen innerhalb der Prozesssteuerung 
aus. Fur spezielle Standardfunktionen stehen sogenannte Funktionsblocke mit 
definierten Kommunikationsschnittstellen zur Verfugung. Diese Funktionsblocke 
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bilden mit entsprechenden Algorithmen, die in den Mikroprozessoren der 
einzelnen Feldgerate abgearbeitet werden, spezielle Anwendungsfunktionen. 
Feldgerate mit Mikroprozessoren werden auch als intelligente Feldgerate oder 
smart field devices bezeichnet 

Ein wesentlicher Aspekt der Funktionsblocke besteht darin, dass sie definierte 
Schnittstellen aulweisen und damit von relativ einfachen bis hin zu komplexen 
Kontrollstrategien, die zwischen verschiedenen Feldgeraten aufgeteilt sind, 
verknupft werden konnen. 

In den Foundation Fieldbus Spezifikationen, die offentlich zuganglich sind, sind 
verschiedene Standardfunktionsblocke spezifiziert. Typische Funktionsblocke 
fur Feldgerate sind, „Analog Input", ,Analog Output", „Discret Input", Discret 
Output", M PID-Controi". Neben diesen Basis-Funktionsblocken gibt es noch 
spezielle Funktionsblocke „Analog Alarm", ^Arithmetic", Device Control". 
Seit neuerem sind auch flexible Funktionsblocke (Flexible Function Blocks) von 
der Foundation Fieldbus spezifiziert, die frei nach der lEC-Norm 61 131 
programmierbar sind (z. B. Supervisory Data Acquisation). 
Weiterhin wird auch auf die lEONorm 61 158 verwiesen, in der neben 
verschiedenen Feldbus-Systemen auch die Foundation® Fieldbus-Technologie 
spezifiziert ist. 

Um Funktionsblocke zu verandern, muss der entsprechende Softwarecode im 
Speicher des Feldgerates ausgetauscht werden. Dies erfolgt meist dadurch, 
dass das entsprechende Speicherelement (EEPROM) ausgetauscht wird. Eine 
andere Moglichkeit besteht darin, den neuen Programmteil (d.h. den neuen 
Softwarecode) uber eine am Feldgerat vorgesehene Service-Schnittstelle z. B. 
von einem Laptop zu ubertragen. Hierfur werden jedoch herstellerspezifische 
Spezial-Programme sogenannte (Software-) Tools benotigt In der Regel sind 
auch die Ubertragungsprotokolle proprietar. 
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Bevor ein Feldgerat eingesetzt werden kann muss es konfiguriert und 
parametriert werden. Hierfur ist u.a. das Laden der Kontrollstrategie in die 
entsprechenden Feldgerate notwendig. 

Eine bekannte Applikation, die dies ermoglicht, ist das System SYSCON (Fa. 
SMAR). Mit dieser Applikation kann auch das korrekte Verschalten der 
einzelnen Funktionsblocke sowie der zeitliche Ablauf der Kontrollstrategie 
getestet werden. 

In der Prozessautomatisierungstechnik werden vielfach Feldgerate 
unterschiedlicher Hersteller eingesetzt, furderen vollstandige Parametrierung 
und Konfigurierung herstellerspezifische Bedienprogramme, die allgemein auch 
als Tools bezeichnet werden, das sind Bedienprogramme (z.B. CommuWin®, 
Fa. Endress+Hauser), die auf Rechnereinheiten wie z.B. Workstations oder 
Laptops ablaufen, notwendig sind. 

Um ein einheitliches Bedienen von Feldgeraten unterschiedlicher Hersteller zu 
ermoglichen wurde von der Profibus® Nutzerorganisation ein Industriestandard, 
FDT (Field Device Tool)- Spezifikationen, geschaffen. 
Die Geratehersteller liefern zu ihren Feldgeraten geratespezifische 
Softwaremodule DTMs (Device Type Manager), die alle Daten und Funktionen 
des jeweiligen Feldgerates kapseln und gleichzeitig grafische Bedienelemente 
liefern. Zur Ausfuhrung benotigen der DTMs als Laufzeitumgebung (runtime 
environment) eine FDT-Frame Anwendung (FDT-Container). Hierbei kann es 
sich um ein einfaches Bedienprogramm (Konfigurier-Tool) oder um eine 
Leitsystemanwendung (Engineering Tool) handeln. 
Die FDT-Spezifikationen legen nur die Schnittstellen nicht aber deren 
Implementierung fest. 

Die zugrundeliegende Software-Architektur basiert auf der Microsoft 
COM/DCOM Technologie. DTMs werden als COM Komponenten (COM- 
.Server) realisiert und sind die Softwareschnittstellen iiber die die FDT-Frame 
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Anwendung (FDT-Client) Zugang zum physikalischen Feldgerat erhalt. Die 
graphischen Bedienelemente sind als Microsoft ActiveX Controls realisiert. Ober 
diese graphischen Schnittstellen erhalt der Nutzer einen einfachen Zugang zum 
physikalischen Feldgerat. 

Neben den Feldgeraten mussen auch noch weitere Gerate in die FDT-Frame 
Anwendung eingebunden werden. Dies Gerate, die Kommunikationsaufgaben 
ubemehmen wie z.B. Gateways, Feldbusadapter, benotigen sogenannte 
Kommunikations- DTMs. 

Ein Kommunikations- DTM (CommDTM) enthalt alle Kommunikationsfunktionen 
und Dialoge, iiber die man die Parameter der Netzwerk bzw. Bus-Anschaltung 
beeinflussen und aktivieren kann. Diese Elemente sind standardmaliig ebenfalls 
als ActiveX-Controls implementiert. Der CommDTM ersetzt bei der 
standardisierten FDT-Schnittstelle die heute ubliche herstellerspezifische 
Konflgurationssoftware einer Netzwerk bzw. Feldbus-Anschaltung. 
Der Kommunikationskanal CommChannel entspricht den Treiber-Bibliotheken. 

Heutzutage bendtigt man zum Bedienen und Konfigurieren von Feldgeraten und 
zum Andem von Softwarecode in Feldgeraten unterschiedliche 
herstellerspezifische Programme (Tools). 

Insbesondere das Andern von Softwarecode in Feldgeraten ist sehr aufwendig 
und kann in der Regel nur von einem Techniker vor Ort direkt am Feldgerat 
vorgenommen werden. Das hierfur benotigte Programm muss aufwendig 
erzeugt und getestet werden. 

Weist die Prozessautomatisierungsanlage des Anwenders Feldgerate 
unterschiedlicher Hersteller auf, so sind unterschiedliche Bedienprogramme und 
unterschiedliche Programme zum Andem von Softwarecode notwendig. 

Dies ist fur den Anwender aufcerst unbefriedigend. 
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Aufgabe der voriaufigen Erfindung ist es deshalb, ein Verfahren zum Ubsrtragen 
von Softwarecode von einer Rechnereinheit zu einem Feldgerat der 
Prozessautomatisierungstechnik anzugeben, das einfach und kostengunstig 
durchgefuhrt werden kann. 

Gelost wird diese Aufgabe durch die in Verfahren 1 angegebenen 
Verfahrensschritte. 

Die wesentlich Idee der Erfindung besteht darin, den Softwarecode, der im 
Feldgerat geladen werden soil, in ein Softwaremodul zu integrieren, das 
verschiedene Daten und Funktionen des Feldgerates kapselt und das als 
Laufzeitumgebung ein Bedienprogramm fur Feldgerate benotigt. Uber das 
Bedienprogramm kommuniziert das Softwaremodul mit dem Feldgerat. Das 
Softwaremodul stellt im wesentlichen den Software-Treiber fur das Feldgerat mit 
alien geratespezifischen Funktionen und Dialogen sowie der Benutzeroberflache 
fur Parametrierung, Konfigurierung, Diagnose und Wartung dar. 

In einer Weiterentwicklung der Erfindung handelt es sich bei dem 
Softwaremodul urn ein DTM (Device Type Manager) und bei dem 
Bedienwerkzeug urn eine FDT- Frame Applikation, die beide den FDT- 
Spezifikationen entsprechen. 

In einer Weiterentwicklung der Erfindung handelt es sich bei dem Softwarecode 
urn einen Funktionsblock. Dieser Funktionsblock kann z. B. nach dem 
Foundation® Fieldbus Spezifikationen ausgebildet sein. 

Ein derartiger Funktionsblock enthalt u.a. die Algorithmen, die Parameter und 
Methoden fur das jeweilige Feldgerat. 
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Dadurch dass beim Ubertragen eines Funktionsblocks in ein Feldgerat dieses 
erheblich manipuliert werden kann, sind Sicherheitsmechanismen notwendig, 
die eine Virusattacke auf das Feldgerat verhindern. 

In einer Weiterentwicklung der Erfindung ist im Feldgerat eine Shell-Applikation 
installiert, die die Ausfuhrung des Funktionsblock, der ins Feldgerat ubertragen 
werden soil, im Feldgerate ermoglicht. 

Nachfolgend ist die Erfindung anhand eines in derZeichnung dargestellten 
Ausfuhrungsbeispiels naher erlautert. Es zeigen: 

Fig. 1 Netzwerk der Prozessautomatisierungstechnik in schematischer 
Darstellung; 

Fig. 2 FDT-Frame-Applikation mit Verbindung zu einem Feldgerat in 
schematischer Darstellung. 

In Fig. 1 ist ein Netzwerk der Prozessautomatisierungstechnik naher dargestellt. 
An einen Datenbus D1 sind mehrere Leistsystemen bzw. Steuereinheiten 
(Workstations) WS1, WS2, die zur Prozessvisualisierung, Prozessuberwachung 
und zum Engineering dienen, angeschlossen. Der Datenbus D1 arbeitet z.B. 
nach dem HSE(High Speed Ethernet)-Standard der Foundation® Fieldbus. Uber 
ein Gateway G1 , das auch als Linking Device bezeichnet wird, ist der Datenbus 
D1 mit einem Feldbussegment SM1 verbunden. Das Feldbussegment SM1 
besteht aus mehreren Feldgeraten F1, F2, F3, F4, die uber einen Feldbus FB 
miteinander verbunden sind. Der Feldbus FB arbeitet nach dem Foundation 
Fieldbus Standard. 

In Fig. 2 ist eine FDT- Frame Applikation, die auf einer der Steuereinheiten 
WS1, bzw. WS2 ablauft, schematisch dargestellt. Bel der FDT Frame 
Applikation kann es sich urn das Bedienprogramm PACTware® (PACTware 
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Consortium e.V.) Oder FieldCare® (Fa. Endress+Hauser) handeln, die eine 
Windows® Umgebung benotigen. Die FDT-Frame Applikation ist verantwortlich 
fur die Projektdatenbank (poject database), die Kommunikation zu den Bus- 
Systemen, die Verwaltung des Feldgerate-Katalogs, die Verwaltung der 
Benutzer und Zugriffsrechte etc. 

Uber verschiedenen Schnittstellen S1, S2 (gemaft FDT-Spezifikationen) erfolgt 
eine Einbindung des Softwaremoduls DTM-1 , das als DTM ausgebildet ist. Der 
DTM-1 kapselt die Daten und Funktionen des Feldgerats F1 und benotigt als 
Laufzeitumgebung die FDT-Frame Applikation. Er ermoglicht den Zugriff auf 
Gerateparameter (Online und Offline), die Geratebedienung und Konfiguration, 
die Diagnose des Geratestatus und eine herstellerspezifische Geratebedienung 
mit entsprechendem Look and Feel. 

Er liefert auch graphische Elemente fur die Bedienung der Feldgerate als 
eigenstandige Windows® Applikationen. 

Gemaft dem FDT-Konzept konnen in die FDT-Frame Applikation verschiedenen 
DTMs unterschiedlicher Hersteller eingebunden werden. 

Uber eine Schnittstelle S3 kommuniziert die FDT-Frame Applikation mit dem 
Feldgerat F1 . Die Hardware-maliige Verbindung erfolgt uber eine Bus- 
Anschaltung BA, den Datenbus D1, das Gateway G1, den Feldbus und die 
Feldbus-Schnittstelle FS1. 

In den DTM-1 ist zusatzlich ein Funktionsblock FB integriert. Der Funktionsblock 
FB besteht aus einem Funktionsblock-User-lnterface FBUI und dem 
eigentlichen Funktionsblock-Softwarecode FBC. Der Softwarecode des 
Funktionsblocks FB ist als Function Block gemaft den Foundation® Fieldbus 
Spezifikationen ausgebildet. 

Dieser Funktionsblock umfasst z.B. Algorithmen, Parameter oder Methoden des 
Feldgerats F1. 
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Uber das Funktionsblock-User-lnterface FBUI konnen insbesondere die 
Parameter des Funktionsblocks verandert werden. 

Nachfolgend ist die Funktionsweise der Erfindung naher erlautert. 
Parameterwerte konnen in einfacher und bekannter Weise von der Steuereinheit 
z. B. WS1 zu den Feldgeraten F1, F2, F3, F4 ubertragen werden. Zuerst wird 
die Kommunikationsverbindung zum physikalischen Gerat hergestellt. FDT stellt 
hierfur die entsprechenden Kommunikationskanale CommChannels zur 
Verfiigung. Nach dem Aufbau der Kommunikationsverbindung wird der 
Softwarecode FBC von der Steuereinheit z.B. WS1 in entsprechender Weise 
zum Feldgerat F1 ubertragen, wie z.B. herkommliche Parameterwerte. Der 
Verbindungsaufbau und die Kommunikation zum physikalischen Gerat ist 
bereits Bestandteil der FDT-Spezifikationen. 

Zur Ausfuhrung des Softwarecodes im Feldgerat F1 ist eine Function Block 
Shell mit entsprechenden Schnittstellen S1',S2' vorgesehen. Die Function Block 
Shell stellt ein Application Programm Interface zwischen Feldbus-Stack und 
Funktionsblock-Anwendungen dar. 

Zur Vermeidung der Ubertragung von herstellerfremden Softwarecode ins 
Feldgerat, ist in der Function Block Shell vorgesehen, die Authentizitat des 
DTMs zu uberprufen. Nur DTMs vom Hersteller zertifizierte DTMs ist es erlaubt, 
Softwarecode in seine Feldgerate zu ubertragen. Somit wird vermieden, dass 
fehlerhafter oder virusverseuchter Softwarecode ins Feldgerat gelangen kann. 

Fur die Obertragung von Softwarecode FBC zu Feldgeraten ist kein 
herstellerspezifisches Programm mehr notwendig. Ein Standard- 
Bedienprogramm ist hierfur ausreichend. Mit einem Bedienprogram, der FDT- 
Frame Applikation, kann in Feldgeraten unterschiedlicher Hersteller, 
Softwarecode geandert werden. Diese Anderungen konnen vom Anwender 
problemlos durchgefuhrt werden. Hierfur muss nur der vom Hersteller des 
Feldgerates bereitgestellte DTM mit dem geanderten Softwarecode in die 
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Steuereinheit geladen werden und uber einen entsprechenden Bildschirm 
Befehl „Software Update durchfuhren" eingeleitet werden. 
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Patentsinsprych© 

Verfahren zum Ubertragen von Softwarecode von einer Steuereinheit zu einem 
Feldgerat der Prozessautomatisierungstechnik, 

dadurch gekennzeichnet, dass der Softwarecode in einem Softwaremodul 
integriert ist, das Daten und Funktionen des Feldgerates kapselt und als 
Laufeeitumgebung ein Bedienprogramm fur Feldgerate benotigt, das die 
Kommunikationsverbindung mit dem Feldgerat herstellt, uber die die 
Ubertragung des Softwarecodes erfolgt. 

Verfahren nach Anspruch 1 , dadurch gekennzeichnet, dass das Softwaremodul 
als DTM (device type manager) gemaft den FDT-Spezifikationen ausgebildet 
und das Bedienprogramm als FDT-Frame-Applikation dient. 

Verfahren nach einem der vorhergehenden Anspruche, dadurch 
gekennzeichnet, dass der Softwarecode einem Funktionsblock entspricht. 

Verfahren nach Anspruch 3, dadurch gekennzeichnet, dass der Funktionsblock 
gemali den Foundation® Fieldbus Spezifikationen als Function Block 
ausgebildet ist. 

Verfahren nach einem der vorhergehenden Anspruche 3 oder 4, dadurch 
gekennzeichnet, dass der Funktionsblock z.B. Algorithmen, Parameter oder 
Methoden des Feldgerats umfasst 
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